71.8 自定义ViewResolvers
ViewResolver
是Spring MVC的核心组件,它负责转换@Controller
中的视图名称到实际的View
实现。注意ViewResolvers
主要用在UI应用中,而不是REST风格的服务(View
不是用来渲染@ResponseBody
的)。Spring有很多你可以选择的ViewResolver
实现,并且Spring自己对如何选择相应实现也没发表意见。另一方面,Spring Boot会根据classpath上的依赖和应用上下文为你安装一或两个ViewResolver
实现。DispatcherServlet
使用所有在应用上下文中找到的解析器(resolvers),并依次尝试每一个直到它获取到结果,所以如果你正在添加自己的解析器,那就要小心顺序和你的解析器添加的位置。
WebMvcAutoConfiguration
将会为你的上下文添加以下ViewResolvers
:
- bean id为
defaultViewResolver
的InternalResourceViewResolver
,它会定位可以使用DefaultServlet
渲染的物理资源(比如静态资源和JSP页面)。它在视图名上应用了一个前缀和后缀(默认都为空,但你可以通过spring.view.prefix
和spring.view.suffix
设置),然后查找在servlet上下文中具有该路径的物理资源,可以通过提供相同类型的bean覆盖它。 - id为
beanNameViewResolver
的BeanNameViewResolver
,它是视图解析器链的一个非常有用的成员,可以在View
解析时收集任何具有相同名称的beans,没必要覆盖或替换它。 - id为
viewResolver
的ContentNegotiatingViewResolver
,它只会在实际View
类型的beans出现时添加。这是一个'master'解析器,它的职责会代理给其他解析器,它会尝试找到客户端发送的一个匹配'Accept'的HTTP头部。这有一篇关于ContentNegotiatingViewResolver的博客,你也可以也查看下源码。通过定义一个名叫'viewResolver'的bean,你可以关闭自动配置的ContentNegotiatingViewResolver
。 - 如果使用Thymeleaf,你将有一个id为
thymeleafViewResolver
的ThymeleafViewResolver
,它会通过加前缀和后缀的视图名来查找资源(外部配置为spring.thymeleaf.prefix
和spring.thymeleaf.suffix
,对应的默认为'classpath:/templates/'和'.html')。你可以通过提供相同名称的bean来覆盖它。 - 如果使用FreeMarker,你将有一个id为
freeMarkerViewResolver
的FreeMarkerViewResolver
,它会使用加前缀和后缀(外部配置为spring.freemarker.prefix
和spring.freemarker.suffix
,对应的默认值为空和'.ftl')的视图名从加载路径(外部配置为spring.freemarker.templateLoaderPath
,默认为'classpath:/templates/')下查找资源。你可以通过提供相同名称的bean来覆盖它。 - 如果使用Groovy模板(实际上只要你把groovy-templates添加到classpath下),你将有一个id为
groovyTemplateViewResolver
的Groovy TemplateViewResolver
,它会使用加前缀和后缀(外部属性为spring.groovy.template.prefix
和spring.groovy.template.suffix
,对应的默认值为'classpath:/templates/'和'.tpl')的视图名从加载路径下查找资源。你可以通过提供相同名称的bean来覆盖它。 - 如果使用Velocity,你将有一个id为
velocityViewResolver
的VelocityViewResolver
,它会使用加前缀和后缀(外部属性为spring.velocity.prefix
和spring.velocity.suffix
,对应的默认值为空和'.vm')的视图名从加载路径(外部属性为spring.velocity.resourceLoaderPath
,默认为'classpath:/templates/')下查找资源。你可以通过提供相同名称的bean来覆盖它。
更多详情可查看源码: WebMvcAutoConfiguration,ThymeleafAutoConfiguration,FreeMarkerAutoConfiguration,GroovyTemplateAutoConfiguration,VelocityAutoConfiguration。